<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=emulateIE7" />
    <title>Coverage for D:\PyCharm\PyCharm 2019.3.1\plugins\python\helpers\pycharm\teamcity\unittestpy.py: 41%</title>
    <link rel="stylesheet" href="style.css" type="text/css">
    <script type="text/javascript" src="jquery.min.js"></script>
    <script type="text/javascript" src="jquery.hotkeys.js"></script>
    <script type="text/javascript" src="jquery.isonscreen.js"></script>
    <script type="text/javascript" src="coverage_html.js"></script>
    <script type="text/javascript">
        jQuery(document).ready(coverage.pyfile_ready);
    </script>
</head>
<body class="pyfile">
<div id="header">
    <div class="content">
        <h1>Coverage for <b>D:\PyCharm\PyCharm 2019.3.1\plugins\python\helpers\pycharm\teamcity\unittestpy.py</b> :
            <span class="pc_cov">41%</span>
        </h1>
        <img id="keyboard_icon" src="keybd_closed.png" alt="Show keyboard shortcuts" />
        <h2 class="stats">
            216 statements &nbsp;
            <span class="run shortkey_r button_toggle_run">89 run</span>
            <span class="mis show_mis shortkey_m button_toggle_mis">127 missing</span>
            <span class="exc show_exc shortkey_x button_toggle_exc">0 excluded</span>
        </h2>
    </div>
</div>
<div class="help_panel">
    <img id="panel_icon" src="keybd_open.png" alt="Hide keyboard shortcuts" />
    <p class="legend">Hot-keys on this page</p>
    <div>
    <p class="keyhelp">
        <span class="key">r</span>
        <span class="key">m</span>
        <span class="key">x</span>
        <span class="key">p</span> &nbsp; toggle line displays
    </p>
    <p class="keyhelp">
        <span class="key">j</span>
        <span class="key">k</span> &nbsp; next/prev highlighted chunk
    </p>
    <p class="keyhelp">
        <span class="key">0</span> &nbsp; (zero) top of page
    </p>
    <p class="keyhelp">
        <span class="key">1</span> &nbsp; (one) first highlighted chunk
    </p>
    </div>
</div>
<div id="source">
    <p id="t1" class="pln"><span class="n"><a href="#t1">1</a></span><span class="t"><span class="com"># coding=utf-8</span>&nbsp;</span><span class="r"></span></p>
    <p id="t2" class="run"><span class="n"><a href="#t2">2</a></span><span class="t"><span class="key">import</span> <span class="nam">sys</span>&nbsp;</span><span class="r"></span></p>
    <p id="t3" class="run"><span class="n"><a href="#t3">3</a></span><span class="t"><span class="key">from</span> <span class="nam">unittest</span> <span class="key">import</span> <span class="nam">TestResult</span><span class="op">,</span> <span class="nam">TextTestRunner</span>&nbsp;</span><span class="r"></span></p>
    <p id="t4" class="run"><span class="n"><a href="#t4">4</a></span><span class="t"><span class="key">import</span> <span class="nam">datetime</span>&nbsp;</span><span class="r"></span></p>
    <p id="t5" class="run"><span class="n"><a href="#t5">5</a></span><span class="t"><span class="key">import</span> <span class="nam">re</span>&nbsp;</span><span class="r"></span></p>
    <p id="t6" class="pln"><span class="n"><a href="#t6">6</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t7" class="run"><span class="n"><a href="#t7">7</a></span><span class="t"><span class="key">from</span> <span class="nam">teamcity</span><span class="op">.</span><span class="nam">messages</span> <span class="key">import</span> <span class="nam">TeamcityServiceMessages</span>&nbsp;</span><span class="r"></span></p>
    <p id="t8" class="run"><span class="n"><a href="#t8">8</a></span><span class="t"><span class="key">from</span> <span class="nam">teamcity</span><span class="op">.</span><span class="nam">common</span> <span class="key">import</span> <span class="nam">is_string</span><span class="op">,</span> <span class="nam">get_class_fullname</span><span class="op">,</span> <span class="nam">convert_error_to_string</span><span class="op">,</span> <span class="xx">\</span>&nbsp;</span><span class="r"></span></p>
    <p id="t9" class="pln"><span class="n"><a href="#t9">9</a></span><span class="t">    <span class="nam">dump_test_stdout</span><span class="op">,</span> <span class="nam">dump_test_stderr</span><span class="op">,</span> <span class="nam">get_exception_message</span><span class="op">,</span> <span class="nam">to_unicode</span><span class="op">,</span> <span class="nam">FlushingStringIO</span>&nbsp;</span><span class="r"></span></p>
    <p id="t10" class="pln"><span class="n"><a href="#t10">10</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t11" class="run"><span class="n"><a href="#t11">11</a></span><span class="t"><span class="key">from</span> <span class="op">.</span><span class="nam">diff_tools</span> <span class="key">import</span> <span class="nam">EqualsAssertionError</span><span class="op">,</span> <span class="nam">patch_unittest_diff</span>&nbsp;</span><span class="r"></span></p>
    <p id="t12" class="pln"><span class="n"><a href="#t12">12</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t13" class="run"><span class="n"><a href="#t13">13</a></span><span class="t"><span class="nam">_real_stdout</span> <span class="op">=</span> <span class="nam">sys</span><span class="op">.</span><span class="nam">stdout</span>&nbsp;</span><span class="r"></span></p>
    <p id="t14" class="run"><span class="n"><a href="#t14">14</a></span><span class="t"><span class="nam">_real_stderr</span> <span class="op">=</span> <span class="nam">sys</span><span class="op">.</span><span class="nam">stderr</span>&nbsp;</span><span class="r"></span></p>
    <p id="t15" class="run"><span class="n"><a href="#t15">15</a></span><span class="t"><span class="nam">_ERROR_HOLDERS_FQN</span> <span class="op">=</span> <span class="op">(</span><span class="str">"unittest.suite._ErrorHolder"</span><span class="op">,</span> <span class="str">"unittest2.suite._ErrorHolder"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t16" class="pln"><span class="n"><a href="#t16">16</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t17" class="pln"><span class="n"><a href="#t17">17</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t18" class="run"><span class="n"><a href="#t18">18</a></span><span class="t"><span class="key">class</span> <span class="nam">TeamcityTestResult</span><span class="op">(</span><span class="nam">TestResult</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t19" class="run"><span class="n"><a href="#t19">19</a></span><span class="t">    <span class="nam">separator2</span> <span class="op">=</span> <span class="str">"\n"</span>&nbsp;</span><span class="r"></span></p>
    <p id="t20" class="pln"><span class="n"><a href="#t20">20</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t21" class="pln"><span class="n"><a href="#t21">21</a></span><span class="t">    <span class="com"># noinspection PyUnusedLocal</span>&nbsp;</span><span class="r"></span></p>
    <p id="t22" class="run"><span class="n"><a href="#t22">22</a></span><span class="t">    <span class="key">def</span> <span class="nam">__init__</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">stream</span><span class="op">=</span><span class="nam">_real_stdout</span><span class="op">,</span> <span class="nam">descriptions</span><span class="op">=</span><span class="key">None</span><span class="op">,</span> <span class="nam">verbosity</span><span class="op">=</span><span class="key">None</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t23" class="run"><span class="n"><a href="#t23">23</a></span><span class="t">        <span class="nam">super</span><span class="op">(</span><span class="nam">TeamcityTestResult</span><span class="op">,</span> <span class="nam">self</span><span class="op">)</span><span class="op">.</span><span class="nam">__init__</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t24" class="pln"><span class="n"><a href="#t24">24</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t25" class="pln"><span class="n"><a href="#t25">25</a></span><span class="t">        <span class="com"># Some code may ask for self.failfast, see unittest2.case.TestCase.subTest</span>&nbsp;</span><span class="r"></span></p>
    <p id="t26" class="run"><span class="n"><a href="#t26">26</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">failfast</span> <span class="op">=</span> <span class="nam">getattr</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="str">"failfast"</span><span class="op">,</span> <span class="key">False</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t27" class="pln"><span class="n"><a href="#t27">27</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t28" class="run"><span class="n"><a href="#t28">28</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">test_started_datetime_map</span> <span class="op">=</span> <span class="op">{</span><span class="op">}</span>&nbsp;</span><span class="r"></span></p>
    <p id="t29" class="run"><span class="n"><a href="#t29">29</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">failed_tests</span> <span class="op">=</span> <span class="nam">set</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t30" class="run"><span class="n"><a href="#t30">30</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">subtest_failures</span> <span class="op">=</span> <span class="op">{</span><span class="op">}</span>&nbsp;</span><span class="r"></span></p>
    <p id="t31" class="run"><span class="n"><a href="#t31">31</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span> <span class="op">=</span> <span class="nam">TeamcityServiceMessages</span><span class="op">(</span><span class="nam">_real_stdout</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t32" class="run"><span class="n"><a href="#t32">32</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">current_test_id</span> <span class="op">=</span> <span class="key">None</span>&nbsp;</span><span class="r"></span></p>
    <p id="t33" class="pln"><span class="n"><a href="#t33">33</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t34" class="run"><span class="n"><a href="#t34">34</a></span><span class="t">    <span class="op">@</span><span class="nam">staticmethod</span>&nbsp;</span><span class="r"></span></p>
    <p id="t35" class="pln"><span class="n"><a href="#t35">35</a></span><span class="t">    <span class="key">def</span> <span class="nam">get_test_id_with_description</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t36" class="run"><span class="n"><a href="#t36">36</a></span><span class="t">        <span class="key">if</span> <span class="nam">is_string</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t37" class="mis show_mis"><span class="n"><a href="#t37">37</a></span><span class="t">            <span class="key">return</span> <span class="nam">test</span>&nbsp;</span><span class="r"></span></p>
    <p id="t38" class="pln"><span class="n"><a href="#t38">38</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t39" class="run"><span class="n"><a href="#t39">39</a></span><span class="t">        <span class="nam">test_class_fullname</span> <span class="op">=</span> <span class="nam">get_class_fullname</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t40" class="run"><span class="n"><a href="#t40">40</a></span><span class="t">        <span class="nam">test_id</span> <span class="op">=</span> <span class="nam">test</span><span class="op">.</span><span class="nam">id</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t41" class="pln"><span class="n"><a href="#t41">41</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t42" class="run"><span class="n"><a href="#t42">42</a></span><span class="t">        <span class="key">if</span> <span class="nam">test_class_fullname</span> <span class="key">in</span> <span class="nam">_ERROR_HOLDERS_FQN</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t43" class="pln"><span class="n"><a href="#t43">43</a></span><span class="t">            <span class="com"># patch setUpModule (__main__) -> __main__.setUpModule</span>&nbsp;</span><span class="r"></span></p>
    <p id="t44" class="mis show_mis"><span class="n"><a href="#t44">44</a></span><span class="t">            <span class="key">return</span> <span class="nam">re</span><span class="op">.</span><span class="nam">sub</span><span class="op">(</span><span class="str">r'^(.*) \((.*)\)$'</span><span class="op">,</span> <span class="str">r'\2.\1'</span><span class="op">,</span> <span class="nam">test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t45" class="pln"><span class="n"><a href="#t45">45</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t46" class="pln"><span class="n"><a href="#t46">46</a></span><span class="t">        <span class="com"># Force test_id for doctests</span>&nbsp;</span><span class="r"></span></p>
    <p id="t47" class="run"><span class="n"><a href="#t47">47</a></span><span class="t">        <span class="key">if</span> <span class="nam">test_class_fullname</span> <span class="op">!=</span> <span class="str">"doctest.DocTestCase"</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t48" class="run"><span class="n"><a href="#t48">48</a></span><span class="t">            <span class="nam">desc</span> <span class="op">=</span> <span class="nam">test</span><span class="op">.</span><span class="nam">shortDescription</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t49" class="run"><span class="n"><a href="#t49">49</a></span><span class="t">            <span class="nam">test_method_name</span> <span class="op">=</span> <span class="nam">getattr</span><span class="op">(</span><span class="nam">test</span><span class="op">,</span> <span class="str">"_testMethodName"</span><span class="op">,</span> <span class="str">""</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t50" class="run"><span class="n"><a href="#t50">50</a></span><span class="t">            <span class="key">if</span> <span class="nam">desc</span> <span class="key">and</span> <span class="nam">desc</span> <span class="op">!=</span> <span class="nam">test_id</span> <span class="key">and</span> <span class="nam">desc</span> <span class="op">!=</span> <span class="nam">test_method_name</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t51" class="mis show_mis"><span class="n"><a href="#t51">51</a></span><span class="t">                <span class="key">return</span> <span class="str">"%s (%s)"</span> <span class="op">%</span> <span class="op">(</span><span class="nam">test_id</span><span class="op">,</span> <span class="nam">desc</span><span class="op">.</span><span class="nam">replace</span><span class="op">(</span><span class="str">'.'</span><span class="op">,</span> <span class="str">'_'</span><span class="op">)</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t52" class="pln"><span class="n"><a href="#t52">52</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t53" class="run"><span class="n"><a href="#t53">53</a></span><span class="t">        <span class="key">return</span> <span class="nam">test_id</span>&nbsp;</span><span class="r"></span></p>
    <p id="t54" class="pln"><span class="n"><a href="#t54">54</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t55" class="run"><span class="n"><a href="#t55">55</a></span><span class="t">    <span class="key">def</span> <span class="nam">addSuccess</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">test</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t56" class="run"><span class="n"><a href="#t56">56</a></span><span class="t">        <span class="nam">super</span><span class="op">(</span><span class="nam">TeamcityTestResult</span><span class="op">,</span> <span class="nam">self</span><span class="op">)</span><span class="op">.</span><span class="nam">addSuccess</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t57" class="pln"><span class="n"><a href="#t57">57</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t58" class="run"><span class="n"><a href="#t58">58</a></span><span class="t">    <span class="key">def</span> <span class="nam">addExpectedFailure</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">test</span><span class="op">,</span> <span class="nam">err</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t59" class="mis show_mis"><span class="n"><a href="#t59">59</a></span><span class="t">        <span class="nam">_super</span> <span class="op">=</span> <span class="nam">super</span><span class="op">(</span><span class="nam">TeamcityTestResult</span><span class="op">,</span> <span class="nam">self</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t60" class="mis show_mis"><span class="n"><a href="#t60">60</a></span><span class="t">        <span class="key">if</span> <span class="nam">hasattr</span><span class="op">(</span><span class="nam">_super</span><span class="op">,</span> <span class="str">"addExpectedFailure"</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t61" class="mis show_mis"><span class="n"><a href="#t61">61</a></span><span class="t">            <span class="nam">_super</span><span class="op">.</span><span class="nam">addExpectedFailure</span><span class="op">(</span><span class="nam">test</span><span class="op">,</span> <span class="nam">err</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t62" class="pln"><span class="n"><a href="#t62">62</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t63" class="mis show_mis"><span class="n"><a href="#t63">63</a></span><span class="t">        <span class="nam">err</span> <span class="op">=</span> <span class="nam">convert_error_to_string</span><span class="op">(</span><span class="nam">err</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t64" class="mis show_mis"><span class="n"><a href="#t64">64</a></span><span class="t">        <span class="nam">test_id</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">get_test_id_with_description</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t65" class="pln"><span class="n"><a href="#t65">65</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t66" class="mis show_mis"><span class="n"><a href="#t66">66</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">testIgnored</span><span class="op">(</span><span class="nam">test_id</span><span class="op">,</span> <span class="nam">message</span><span class="op">=</span><span class="str">"Expected failure: "</span> <span class="op">+</span> <span class="nam">err</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t67" class="pln"><span class="n"><a href="#t67">67</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t68" class="run"><span class="n"><a href="#t68">68</a></span><span class="t">    <span class="key">def</span> <span class="nam">get_subtest_block_id</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">test</span><span class="op">,</span> <span class="nam">subtest</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t69" class="mis show_mis"><span class="n"><a href="#t69">69</a></span><span class="t">        <span class="nam">test_id</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">get_test_id_with_description</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t70" class="mis show_mis"><span class="n"><a href="#t70">70</a></span><span class="t">        <span class="nam">subtest_id</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">get_test_id_with_description</span><span class="op">(</span><span class="nam">subtest</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t71" class="pln"><span class="n"><a href="#t71">71</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t72" class="mis show_mis"><span class="n"><a href="#t72">72</a></span><span class="t">        <span class="key">if</span> <span class="nam">subtest_id</span><span class="op">.</span><span class="nam">startswith</span><span class="op">(</span><span class="nam">test_id</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t73" class="mis show_mis"><span class="n"><a href="#t73">73</a></span><span class="t">            <span class="nam">block_id</span> <span class="op">=</span> <span class="nam">subtest_id</span><span class="op">[</span><span class="nam">len</span><span class="op">(</span><span class="nam">test_id</span><span class="op">)</span><span class="op">:</span><span class="op">]</span><span class="op">.</span><span class="nam">strip</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t74" class="pln"><span class="n"><a href="#t74">74</a></span><span class="t">        <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t75" class="mis show_mis"><span class="n"><a href="#t75">75</a></span><span class="t">            <span class="nam">block_id</span> <span class="op">=</span> <span class="nam">subtest_id</span>&nbsp;</span><span class="r"></span></p>
    <p id="t76" class="mis show_mis"><span class="n"><a href="#t76">76</a></span><span class="t">        <span class="key">if</span> <span class="nam">len</span><span class="op">(</span><span class="nam">block_id</span><span class="op">)</span> <span class="op">==</span> <span class="num">0</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t77" class="mis show_mis"><span class="n"><a href="#t77">77</a></span><span class="t">            <span class="nam">block_id</span> <span class="op">=</span> <span class="nam">test_id</span>&nbsp;</span><span class="r"></span></p>
    <p id="t78" class="mis show_mis"><span class="n"><a href="#t78">78</a></span><span class="t">        <span class="key">return</span> <span class="nam">block_id</span>&nbsp;</span><span class="r"></span></p>
    <p id="t79" class="pln"><span class="n"><a href="#t79">79</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t80" class="run"><span class="n"><a href="#t80">80</a></span><span class="t">    <span class="key">def</span> <span class="nam">addSkip</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">test</span><span class="op">,</span> <span class="nam">reason</span><span class="op">=</span><span class="str">""</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t81" class="mis show_mis"><span class="n"><a href="#t81">81</a></span><span class="t">        <span class="key">if</span> <span class="nam">sys</span><span class="op">.</span><span class="nam">version_info</span> <span class="op">>=</span> <span class="op">(</span><span class="num">2</span><span class="op">,</span> <span class="num">7</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t82" class="mis show_mis"><span class="n"><a href="#t82">82</a></span><span class="t">            <span class="nam">super</span><span class="op">(</span><span class="nam">TeamcityTestResult</span><span class="op">,</span> <span class="nam">self</span><span class="op">)</span><span class="op">.</span><span class="nam">addSkip</span><span class="op">(</span><span class="nam">test</span><span class="op">,</span> <span class="nam">reason</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t83" class="pln"><span class="n"><a href="#t83">83</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t84" class="mis show_mis"><span class="n"><a href="#t84">84</a></span><span class="t">        <span class="key">if</span> <span class="nam">reason</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t85" class="mis show_mis"><span class="n"><a href="#t85">85</a></span><span class="t">            <span class="key">if</span> <span class="nam">isinstance</span><span class="op">(</span><span class="nam">reason</span><span class="op">,</span> <span class="nam">Exception</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t86" class="mis show_mis"><span class="n"><a href="#t86">86</a></span><span class="t">                <span class="nam">reason_str</span> <span class="op">=</span> <span class="str">": "</span> <span class="op">+</span> <span class="nam">get_exception_message</span><span class="op">(</span><span class="nam">reason</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t87" class="pln"><span class="n"><a href="#t87">87</a></span><span class="t">            <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t88" class="mis show_mis"><span class="n"><a href="#t88">88</a></span><span class="t">                <span class="nam">reason_str</span> <span class="op">=</span> <span class="str">": "</span> <span class="op">+</span> <span class="nam">to_unicode</span><span class="op">(</span><span class="nam">reason</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t89" class="pln"><span class="n"><a href="#t89">89</a></span><span class="t">        <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t90" class="mis show_mis"><span class="n"><a href="#t90">90</a></span><span class="t">            <span class="nam">reason_str</span> <span class="op">=</span> <span class="str">""</span>&nbsp;</span><span class="r"></span></p>
    <p id="t91" class="pln"><span class="n"><a href="#t91">91</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t92" class="mis show_mis"><span class="n"><a href="#t92">92</a></span><span class="t">        <span class="nam">test_class_name</span> <span class="op">=</span> <span class="nam">get_class_fullname</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t93" class="mis show_mis"><span class="n"><a href="#t93">93</a></span><span class="t">        <span class="key">if</span> <span class="nam">test_class_name</span> <span class="op">==</span> <span class="str">"unittest.case._SubTest"</span> <span class="key">or</span> <span class="nam">test_class_name</span> <span class="op">==</span> <span class="str">"unittest2.case._SubTest"</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t94" class="mis show_mis"><span class="n"><a href="#t94">94</a></span><span class="t">            <span class="nam">parent_test</span> <span class="op">=</span> <span class="nam">test</span><span class="op">.</span><span class="nam">test_case</span>&nbsp;</span><span class="r"></span></p>
    <p id="t95" class="mis show_mis"><span class="n"><a href="#t95">95</a></span><span class="t">            <span class="nam">parent_test_id</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">get_test_id_with_description</span><span class="op">(</span><span class="nam">parent_test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t96" class="mis show_mis"><span class="n"><a href="#t96">96</a></span><span class="t">            <span class="nam">subtest</span> <span class="op">=</span> <span class="nam">test</span>&nbsp;</span><span class="r"></span></p>
    <p id="t97" class="pln"><span class="n"><a href="#t97">97</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t98" class="mis show_mis"><span class="n"><a href="#t98">98</a></span><span class="t">            <span class="nam">block_id</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">get_subtest_block_id</span><span class="op">(</span><span class="nam">parent_test</span><span class="op">,</span> <span class="nam">subtest</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t99" class="pln"><span class="n"><a href="#t99">99</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t100" class="mis show_mis"><span class="n"><a href="#t100">100</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">subTestBlockOpened</span><span class="op">(</span><span class="nam">block_id</span><span class="op">,</span> <span class="nam">subTestResult</span><span class="op">=</span><span class="str">"Skip"</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">parent_test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t101" class="mis show_mis"><span class="n"><a href="#t101">101</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">testStdOut</span><span class="op">(</span><span class="nam">parent_test_id</span><span class="op">,</span> <span class="nam">out</span><span class="op">=</span><span class="str">"SubTest skipped"</span> <span class="op">+</span> <span class="nam">reason_str</span> <span class="op">+</span> <span class="str">"\n"</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">parent_test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t102" class="mis show_mis"><span class="n"><a href="#t102">102</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">blockClosed</span><span class="op">(</span><span class="nam">block_id</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">parent_test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t103" class="pln"><span class="n"><a href="#t103">103</a></span><span class="t">        <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t104" class="mis show_mis"><span class="n"><a href="#t104">104</a></span><span class="t">            <span class="nam">test_id</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">get_test_id_with_description</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t105" class="pln"><span class="n"><a href="#t105">105</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t106" class="mis show_mis"><span class="n"><a href="#t106">106</a></span><span class="t">            <span class="key">if</span> <span class="nam">test_id</span> <span class="key">not</span> <span class="key">in</span> <span class="nam">self</span><span class="op">.</span><span class="nam">test_started_datetime_map</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t107" class="pln"><span class="n"><a href="#t107">107</a></span><span class="t">                <span class="com"># Test ignored without startTest. Handle start and finish events ourselves</span>&nbsp;</span><span class="r"></span></p>
    <p id="t108" class="mis show_mis"><span class="n"><a href="#t108">108</a></span><span class="t">                <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">testStarted</span><span class="op">(</span><span class="nam">test_id</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t109" class="mis show_mis"><span class="n"><a href="#t109">109</a></span><span class="t">                <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">testIgnored</span><span class="op">(</span><span class="nam">test_id</span><span class="op">,</span> <span class="nam">message</span><span class="op">=</span><span class="str">"Skipped"</span> <span class="op">+</span> <span class="nam">reason_str</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t110" class="mis show_mis"><span class="n"><a href="#t110">110</a></span><span class="t">                <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">testFinished</span><span class="op">(</span><span class="nam">test_id</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t111" class="pln"><span class="n"><a href="#t111">111</a></span><span class="t">            <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t112" class="mis show_mis"><span class="n"><a href="#t112">112</a></span><span class="t">                <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">testIgnored</span><span class="op">(</span><span class="nam">test_id</span><span class="op">,</span> <span class="nam">message</span><span class="op">=</span><span class="str">"Skipped"</span> <span class="op">+</span> <span class="nam">reason_str</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t113" class="pln"><span class="n"><a href="#t113">113</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t114" class="run"><span class="n"><a href="#t114">114</a></span><span class="t">    <span class="key">def</span> <span class="nam">addUnexpectedSuccess</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">test</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t115" class="mis show_mis"><span class="n"><a href="#t115">115</a></span><span class="t">        <span class="nam">_super</span> <span class="op">=</span> <span class="nam">super</span><span class="op">(</span><span class="nam">TeamcityTestResult</span><span class="op">,</span> <span class="nam">self</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t116" class="mis show_mis"><span class="n"><a href="#t116">116</a></span><span class="t">        <span class="key">if</span> <span class="nam">hasattr</span><span class="op">(</span><span class="nam">_super</span><span class="op">,</span> <span class="str">"addUnexpectedSuccess"</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t117" class="mis show_mis"><span class="n"><a href="#t117">117</a></span><span class="t">            <span class="nam">_super</span><span class="op">.</span><span class="nam">addUnexpectedSuccess</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t118" class="pln"><span class="n"><a href="#t118">118</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t119" class="mis show_mis"><span class="n"><a href="#t119">119</a></span><span class="t">        <span class="nam">test_id</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">get_test_id_with_description</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t120" class="mis show_mis"><span class="n"><a href="#t120">120</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">testFailed</span><span class="op">(</span><span class="nam">test_id</span><span class="op">,</span> <span class="nam">message</span><span class="op">=</span><span class="str">'Failure'</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
    <p id="t121" class="pln"><span class="n"><a href="#t121">121</a></span><span class="t">                                 <span class="nam">details</span><span class="op">=</span><span class="str">"Test should not succeed since it's marked with @unittest.expectedFailure"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
    <p id="t122" class="pln"><span class="n"><a href="#t122">122</a></span><span class="t">                                 <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t123" class="pln"><span class="n"><a href="#t123">123</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t124" class="run"><span class="n"><a href="#t124">124</a></span><span class="t">    <span class="key">def</span> <span class="nam">addError</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">test</span><span class="op">,</span> <span class="nam">err</span><span class="op">,</span> <span class="op">*</span><span class="nam">k</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t125" class="mis show_mis"><span class="n"><a href="#t125">125</a></span><span class="t">        <span class="nam">super</span><span class="op">(</span><span class="nam">TeamcityTestResult</span><span class="op">,</span> <span class="nam">self</span><span class="op">)</span><span class="op">.</span><span class="nam">addError</span><span class="op">(</span><span class="nam">test</span><span class="op">,</span> <span class="nam">err</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t126" class="pln"><span class="n"><a href="#t126">126</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t127" class="mis show_mis"><span class="n"><a href="#t127">127</a></span><span class="t">        <span class="nam">test_class</span> <span class="op">=</span> <span class="nam">get_class_fullname</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t128" class="mis show_mis"><span class="n"><a href="#t128">128</a></span><span class="t">        <span class="key">if</span> <span class="nam">test_class</span> <span class="key">in</span> <span class="nam">_ERROR_HOLDERS_FQN</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t129" class="pln"><span class="n"><a href="#t129">129</a></span><span class="t">            <span class="com"># This is a standalone error</span>&nbsp;</span><span class="r"></span></p>
    <p id="t130" class="mis show_mis"><span class="n"><a href="#t130">130</a></span><span class="t">            <span class="nam">test_id</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">get_test_id_with_description</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t131" class="pln"><span class="n"><a href="#t131">131</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t132" class="mis show_mis"><span class="n"><a href="#t132">132</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">testStarted</span><span class="op">(</span><span class="nam">test_id</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t133" class="mis show_mis"><span class="n"><a href="#t133">133</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">report_fail</span><span class="op">(</span><span class="nam">test</span><span class="op">,</span> <span class="str">'Failure'</span><span class="op">,</span> <span class="nam">err</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t134" class="mis show_mis"><span class="n"><a href="#t134">134</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">testFinished</span><span class="op">(</span><span class="nam">test_id</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t135" class="mis show_mis"><span class="n"><a href="#t135">135</a></span><span class="t">        <span class="key">elif</span> <span class="nam">get_class_fullname</span><span class="op">(</span><span class="nam">err</span><span class="op">[</span><span class="num">0</span><span class="op">]</span><span class="op">)</span> <span class="op">==</span> <span class="str">"unittest2.case.SkipTest"</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t136" class="mis show_mis"><span class="n"><a href="#t136">136</a></span><span class="t">            <span class="nam">message</span> <span class="op">=</span> <span class="str">""</span>&nbsp;</span><span class="r"></span></p>
    <p id="t137" class="mis show_mis"><span class="n"><a href="#t137">137</a></span><span class="t">            <span class="key">if</span> <span class="nam">hasattr</span><span class="op">(</span><span class="nam">err</span><span class="op">[</span><span class="num">1</span><span class="op">]</span><span class="op">,</span> <span class="str">"message"</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t138" class="mis show_mis"><span class="n"><a href="#t138">138</a></span><span class="t">                <span class="nam">message</span> <span class="op">=</span> <span class="nam">getattr</span><span class="op">(</span><span class="nam">err</span><span class="op">[</span><span class="num">1</span><span class="op">]</span><span class="op">,</span> <span class="str">"message"</span><span class="op">,</span> <span class="str">""</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t139" class="mis show_mis"><span class="n"><a href="#t139">139</a></span><span class="t">            <span class="key">elif</span> <span class="nam">hasattr</span><span class="op">(</span><span class="nam">err</span><span class="op">[</span><span class="num">1</span><span class="op">]</span><span class="op">,</span> <span class="str">"args"</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t140" class="mis show_mis"><span class="n"><a href="#t140">140</a></span><span class="t">                <span class="nam">message</span> <span class="op">=</span> <span class="nam">getattr</span><span class="op">(</span><span class="nam">err</span><span class="op">[</span><span class="num">1</span><span class="op">]</span><span class="op">,</span> <span class="str">"args"</span><span class="op">,</span> <span class="op">[</span><span class="str">""</span><span class="op">]</span><span class="op">)</span><span class="op">[</span><span class="num">0</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
    <p id="t141" class="mis show_mis"><span class="n"><a href="#t141">141</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">addSkip</span><span class="op">(</span><span class="nam">test</span><span class="op">,</span> <span class="nam">message</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t142" class="pln"><span class="n"><a href="#t142">142</a></span><span class="t">        <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t143" class="mis show_mis"><span class="n"><a href="#t143">143</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">report_fail</span><span class="op">(</span><span class="nam">test</span><span class="op">,</span> <span class="str">'Error'</span><span class="op">,</span> <span class="nam">err</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t144" class="pln"><span class="n"><a href="#t144">144</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t145" class="run"><span class="n"><a href="#t145">145</a></span><span class="t">    <span class="key">def</span> <span class="nam">addFailure</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">test</span><span class="op">,</span> <span class="nam">err</span><span class="op">,</span> <span class="op">*</span><span class="nam">k</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t146" class="mis show_mis"><span class="n"><a href="#t146">146</a></span><span class="t">        <span class="nam">super</span><span class="op">(</span><span class="nam">TeamcityTestResult</span><span class="op">,</span> <span class="nam">self</span><span class="op">)</span><span class="op">.</span><span class="nam">addFailure</span><span class="op">(</span><span class="nam">test</span><span class="op">,</span> <span class="nam">err</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t147" class="pln"><span class="n"><a href="#t147">147</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t148" class="mis show_mis"><span class="n"><a href="#t148">148</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">report_fail</span><span class="op">(</span><span class="nam">test</span><span class="op">,</span> <span class="str">'Failure'</span><span class="op">,</span> <span class="nam">err</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t149" class="pln"><span class="n"><a href="#t149">149</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t150" class="run"><span class="n"><a href="#t150">150</a></span><span class="t">    <span class="key">def</span> <span class="nam">addSubTest</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">test</span><span class="op">,</span> <span class="nam">subtest</span><span class="op">,</span> <span class="nam">err</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t151" class="mis show_mis"><span class="n"><a href="#t151">151</a></span><span class="t">        <span class="nam">_super</span> <span class="op">=</span> <span class="nam">super</span><span class="op">(</span><span class="nam">TeamcityTestResult</span><span class="op">,</span> <span class="nam">self</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t152" class="mis show_mis"><span class="n"><a href="#t152">152</a></span><span class="t">        <span class="key">if</span> <span class="nam">hasattr</span><span class="op">(</span><span class="nam">_super</span><span class="op">,</span> <span class="str">"addSubTest"</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t153" class="mis show_mis"><span class="n"><a href="#t153">153</a></span><span class="t">            <span class="nam">_super</span><span class="op">.</span><span class="nam">addSubTest</span><span class="op">(</span><span class="nam">test</span><span class="op">,</span> <span class="nam">subtest</span><span class="op">,</span> <span class="nam">err</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t154" class="pln"><span class="n"><a href="#t154">154</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t155" class="pln"><span class="n"><a href="#t155">155</a></span><span class="t">        <span class="com"># test_id_with_desc may contain description which breaks process of fetching id from subtest</span>&nbsp;</span><span class="r"></span></p>
    <p id="t156" class="mis show_mis"><span class="n"><a href="#t156">156</a></span><span class="t">        <span class="nam">test_id_with_desc</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">get_test_id_with_description</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t157" class="mis show_mis"><span class="n"><a href="#t157">157</a></span><span class="t">        <span class="nam">test_id</span> <span class="op">=</span> <span class="nam">test</span><span class="op">.</span><span class="nam">id</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t158" class="mis show_mis"><span class="n"><a href="#t158">158</a></span><span class="t">        <span class="nam">subtest_id</span> <span class="op">=</span> <span class="nam">subtest</span><span class="op">.</span><span class="nam">id</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t159" class="pln"><span class="n"><a href="#t159">159</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t160" class="mis show_mis"><span class="n"><a href="#t160">160</a></span><span class="t">        <span class="key">if</span> <span class="nam">subtest_id</span><span class="op">.</span><span class="nam">startswith</span><span class="op">(</span><span class="nam">test_id</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t161" class="pln"><span class="n"><a href="#t161">161</a></span><span class="t">            <span class="com"># Replace "." -> "_" since '.' is a test hierarchy separator</span>&nbsp;</span><span class="r"></span></p>
    <p id="t162" class="pln"><span class="n"><a href="#t162">162</a></span><span class="t">            <span class="com"># See i.e. https://github.com/JetBrains/teamcity-messages/issues/134 (https://youtrack.jetbrains.com/issue/PY-23846)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t163" class="mis show_mis"><span class="n"><a href="#t163">163</a></span><span class="t">            <span class="nam">block_id</span> <span class="op">=</span> <span class="nam">subtest_id</span><span class="op">[</span><span class="nam">len</span><span class="op">(</span><span class="nam">test_id</span><span class="op">)</span><span class="op">:</span><span class="op">]</span><span class="op">.</span><span class="nam">strip</span><span class="op">(</span><span class="op">)</span><span class="op">.</span><span class="nam">replace</span><span class="op">(</span><span class="str">"."</span><span class="op">,</span> <span class="str">"_"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t164" class="pln"><span class="n"><a href="#t164">164</a></span><span class="t">        <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t165" class="mis show_mis"><span class="n"><a href="#t165">165</a></span><span class="t">            <span class="nam">block_id</span> <span class="op">=</span> <span class="nam">subtest_id</span>&nbsp;</span><span class="r"></span></p>
    <p id="t166" class="mis show_mis"><span class="n"><a href="#t166">166</a></span><span class="t">        <span class="key">if</span> <span class="nam">len</span><span class="op">(</span><span class="nam">block_id</span><span class="op">)</span> <span class="op">==</span> <span class="num">0</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t167" class="mis show_mis"><span class="n"><a href="#t167">167</a></span><span class="t">            <span class="nam">block_id</span> <span class="op">=</span> <span class="nam">subtest_id</span>&nbsp;</span><span class="r"></span></p>
    <p id="t168" class="pln"><span class="n"><a href="#t168">168</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t169" class="mis show_mis"><span class="n"><a href="#t169">169</a></span><span class="t">        <span class="key">if</span> <span class="nam">err</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t170" class="mis show_mis"><span class="n"><a href="#t170">170</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">add_subtest_failure</span><span class="op">(</span><span class="nam">test_id_with_desc</span><span class="op">,</span> <span class="nam">block_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t171" class="pln"><span class="n"><a href="#t171">171</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t172" class="mis show_mis"><span class="n"><a href="#t172">172</a></span><span class="t">            <span class="key">if</span> <span class="nam">issubclass</span><span class="op">(</span><span class="nam">err</span><span class="op">[</span><span class="num">0</span><span class="op">]</span><span class="op">,</span> <span class="nam">test</span><span class="op">.</span><span class="nam">failureException</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t173" class="mis show_mis"><span class="n"><a href="#t173">173</a></span><span class="t">                <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">subTestBlockOpened</span><span class="op">(</span><span class="nam">block_id</span><span class="op">,</span> <span class="nam">subTestResult</span><span class="op">=</span><span class="str">"Failure"</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id_with_desc</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t174" class="mis show_mis"><span class="n"><a href="#t174">174</a></span><span class="t">                <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">testStdErr</span><span class="op">(</span><span class="nam">test_id_with_desc</span><span class="op">,</span> <span class="nam">out</span><span class="op">=</span><span class="str">"SubTest failure: %s\n"</span> <span class="op">%</span> <span class="nam">convert_error_to_string</span><span class="op">(</span><span class="nam">err</span><span class="op">)</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id_with_desc</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t175" class="mis show_mis"><span class="n"><a href="#t175">175</a></span><span class="t">                <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">blockClosed</span><span class="op">(</span><span class="nam">block_id</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id_with_desc</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t176" class="pln"><span class="n"><a href="#t176">176</a></span><span class="t">            <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t177" class="mis show_mis"><span class="n"><a href="#t177">177</a></span><span class="t">                <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">subTestBlockOpened</span><span class="op">(</span><span class="nam">block_id</span><span class="op">,</span> <span class="nam">subTestResult</span><span class="op">=</span><span class="str">"Error"</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id_with_desc</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t178" class="mis show_mis"><span class="n"><a href="#t178">178</a></span><span class="t">                <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">testStdErr</span><span class="op">(</span><span class="nam">test_id_with_desc</span><span class="op">,</span> <span class="nam">out</span><span class="op">=</span><span class="str">"SubTest error: %s\n"</span> <span class="op">%</span> <span class="nam">convert_error_to_string</span><span class="op">(</span><span class="nam">err</span><span class="op">)</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id_with_desc</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t179" class="mis show_mis"><span class="n"><a href="#t179">179</a></span><span class="t">                <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">blockClosed</span><span class="op">(</span><span class="nam">block_id</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id_with_desc</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t180" class="pln"><span class="n"><a href="#t180">180</a></span><span class="t">        <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t181" class="mis show_mis"><span class="n"><a href="#t181">181</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">subTestBlockOpened</span><span class="op">(</span><span class="nam">block_id</span><span class="op">,</span> <span class="nam">subTestResult</span><span class="op">=</span><span class="str">"Success"</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id_with_desc</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t182" class="mis show_mis"><span class="n"><a href="#t182">182</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">blockClosed</span><span class="op">(</span><span class="nam">block_id</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id_with_desc</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t183" class="pln"><span class="n"><a href="#t183">183</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t184" class="run"><span class="n"><a href="#t184">184</a></span><span class="t">    <span class="key">def</span> <span class="nam">add_subtest_failure</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">test_id</span><span class="op">,</span> <span class="nam">subtest_block_id</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t185" class="mis show_mis"><span class="n"><a href="#t185">185</a></span><span class="t">        <span class="nam">fail_array</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">subtest_failures</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="nam">test_id</span><span class="op">,</span> <span class="op">[</span><span class="op">]</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t186" class="mis show_mis"><span class="n"><a href="#t186">186</a></span><span class="t">        <span class="nam">fail_array</span><span class="op">.</span><span class="nam">append</span><span class="op">(</span><span class="nam">subtest_block_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t187" class="mis show_mis"><span class="n"><a href="#t187">187</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">subtest_failures</span><span class="op">[</span><span class="nam">test_id</span><span class="op">]</span> <span class="op">=</span> <span class="nam">fail_array</span>&nbsp;</span><span class="r"></span></p>
    <p id="t188" class="pln"><span class="n"><a href="#t188">188</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t189" class="run"><span class="n"><a href="#t189">189</a></span><span class="t">    <span class="key">def</span> <span class="nam">get_subtest_failure</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">test_id</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t190" class="run"><span class="n"><a href="#t190">190</a></span><span class="t">        <span class="nam">fail_array</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">subtest_failures</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="nam">test_id</span><span class="op">,</span> <span class="op">[</span><span class="op">]</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t191" class="run"><span class="n"><a href="#t191">191</a></span><span class="t">        <span class="key">return</span> <span class="str">", "</span><span class="op">.</span><span class="nam">join</span><span class="op">(</span><span class="nam">fail_array</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t192" class="pln"><span class="n"><a href="#t192">192</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t193" class="run"><span class="n"><a href="#t193">193</a></span><span class="t">    <span class="key">def</span> <span class="nam">report_fail</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">test</span><span class="op">,</span> <span class="nam">fail_type</span><span class="op">,</span> <span class="nam">err</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t194" class="mis show_mis"><span class="n"><a href="#t194">194</a></span><span class="t">        <span class="nam">test_id</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">get_test_id_with_description</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t195" class="pln"><span class="n"><a href="#t195">195</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t196" class="mis show_mis"><span class="n"><a href="#t196">196</a></span><span class="t">        <span class="nam">diff_failed</span> <span class="op">=</span> <span class="key">None</span>&nbsp;</span><span class="r"></span></p>
    <p id="t197" class="mis show_mis"><span class="n"><a href="#t197">197</a></span><span class="t">        <span class="key">try</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t198" class="mis show_mis"><span class="n"><a href="#t198">198</a></span><span class="t">            <span class="nam">error</span> <span class="op">=</span> <span class="nam">err</span><span class="op">[</span><span class="num">1</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
    <p id="t199" class="mis show_mis"><span class="n"><a href="#t199">199</a></span><span class="t">            <span class="key">if</span> <span class="nam">isinstance</span><span class="op">(</span><span class="nam">error</span><span class="op">,</span> <span class="nam">EqualsAssertionError</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t200" class="mis show_mis"><span class="n"><a href="#t200">200</a></span><span class="t">                <span class="nam">diff_failed</span> <span class="op">=</span> <span class="nam">error</span>&nbsp;</span><span class="r"></span></p>
    <p id="t201" class="mis show_mis"><span class="n"><a href="#t201">201</a></span><span class="t">        <span class="key">except</span> <span class="nam">Exception</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t202" class="mis show_mis"><span class="n"><a href="#t202">202</a></span><span class="t">            <span class="key">pass</span>&nbsp;</span><span class="r"></span></p>
    <p id="t203" class="pln"><span class="n"><a href="#t203">203</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t204" class="mis show_mis"><span class="n"><a href="#t204">204</a></span><span class="t">        <span class="key">if</span> <span class="nam">is_string</span><span class="op">(</span><span class="nam">err</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t205" class="mis show_mis"><span class="n"><a href="#t205">205</a></span><span class="t">            <span class="nam">details</span> <span class="op">=</span> <span class="nam">err</span>&nbsp;</span><span class="r"></span></p>
    <p id="t206" class="pln"><span class="n"><a href="#t206">206</a></span><span class="t">        <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t207" class="mis show_mis"><span class="n"><a href="#t207">207</a></span><span class="t">            <span class="key">try</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t208" class="mis show_mis"><span class="n"><a href="#t208">208</a></span><span class="t">                <span class="nam">details</span> <span class="op">=</span> <span class="nam">err</span><span class="op">.</span><span class="nam">getTraceback</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t209" class="mis show_mis"><span class="n"><a href="#t209">209</a></span><span class="t">            <span class="key">except</span> <span class="nam">AttributeError</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t210" class="mis show_mis"><span class="n"><a href="#t210">210</a></span><span class="t">                <span class="nam">frames_to_skip_from_tail</span> <span class="op">=</span> <span class="num">2</span> <span class="key">if</span> <span class="nam">diff_failed</span> <span class="key">else</span> <span class="num">0</span>&nbsp;</span><span class="r"></span></p>
    <p id="t211" class="mis show_mis"><span class="n"><a href="#t211">211</a></span><span class="t">                <span class="nam">details</span> <span class="op">=</span> <span class="nam">convert_error_to_string</span><span class="op">(</span><span class="nam">err</span><span class="op">,</span> <span class="nam">frames_to_skip_from_tail</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t212" class="pln"><span class="n"><a href="#t212">212</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t213" class="mis show_mis"><span class="n"><a href="#t213">213</a></span><span class="t">        <span class="nam">subtest_failures</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">get_subtest_failure</span><span class="op">(</span><span class="nam">test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t214" class="mis show_mis"><span class="n"><a href="#t214">214</a></span><span class="t">        <span class="key">if</span> <span class="nam">subtest_failures</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t215" class="mis show_mis"><span class="n"><a href="#t215">215</a></span><span class="t">            <span class="nam">details</span> <span class="op">=</span> <span class="str">"Failed subtests list: "</span> <span class="op">+</span> <span class="nam">subtest_failures</span> <span class="op">+</span> <span class="str">"\n\n"</span> <span class="op">+</span> <span class="nam">details</span><span class="op">.</span><span class="nam">strip</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t216" class="mis show_mis"><span class="n"><a href="#t216">216</a></span><span class="t">            <span class="nam">details</span> <span class="op">=</span> <span class="nam">details</span><span class="op">.</span><span class="nam">strip</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t217" class="pln"><span class="n"><a href="#t217">217</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t218" class="mis show_mis"><span class="n"><a href="#t218">218</a></span><span class="t">        <span class="key">if</span> <span class="nam">diff_failed</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t219" class="mis show_mis"><span class="n"><a href="#t219">219</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">testFailed</span><span class="op">(</span><span class="nam">test_id</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
    <p id="t220" class="pln"><span class="n"><a href="#t220">220</a></span><span class="t">                                     <span class="nam">message</span><span class="op">=</span><span class="nam">diff_failed</span><span class="op">.</span><span class="nam">msg</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
    <p id="t221" class="pln"><span class="n"><a href="#t221">221</a></span><span class="t">                                     <span class="nam">details</span><span class="op">=</span><span class="nam">details</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
    <p id="t222" class="pln"><span class="n"><a href="#t222">222</a></span><span class="t">                                     <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
    <p id="t223" class="pln"><span class="n"><a href="#t223">223</a></span><span class="t">                                     <span class="nam">comparison_failure</span><span class="op">=</span><span class="nam">diff_failed</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t224" class="pln"><span class="n"><a href="#t224">224</a></span><span class="t">        <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t225" class="mis show_mis"><span class="n"><a href="#t225">225</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">testFailed</span><span class="op">(</span><span class="nam">test_id</span><span class="op">,</span> <span class="nam">message</span><span class="op">=</span><span class="nam">fail_type</span><span class="op">,</span> <span class="nam">details</span><span class="op">=</span><span class="nam">details</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t226" class="mis show_mis"><span class="n"><a href="#t226">226</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">failed_tests</span><span class="op">.</span><span class="nam">add</span><span class="op">(</span><span class="nam">test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t227" class="pln"><span class="n"><a href="#t227">227</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t228" class="run"><span class="n"><a href="#t228">228</a></span><span class="t">    <span class="key">def</span> <span class="nam">startTest</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">test</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t229" class="run"><span class="n"><a href="#t229">229</a></span><span class="t">        <span class="nam">test_id</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">get_test_id_with_description</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t230" class="run"><span class="n"><a href="#t230">230</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">current_test_id</span> <span class="op">=</span> <span class="nam">test_id</span>&nbsp;</span><span class="r"></span></p>
    <p id="t231" class="pln"><span class="n"><a href="#t231">231</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t232" class="run"><span class="n"><a href="#t232">232</a></span><span class="t">        <span class="nam">super</span><span class="op">(</span><span class="nam">TeamcityTestResult</span><span class="op">,</span> <span class="nam">self</span><span class="op">)</span><span class="op">.</span><span class="nam">startTest</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t233" class="pln"><span class="n"><a href="#t233">233</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t234" class="run"><span class="n"><a href="#t234">234</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">test_started_datetime_map</span><span class="op">[</span><span class="nam">test_id</span><span class="op">]</span> <span class="op">=</span> <span class="nam">datetime</span><span class="op">.</span><span class="nam">datetime</span><span class="op">.</span><span class="nam">now</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t235" class="run"><span class="n"><a href="#t235">235</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">testStarted</span><span class="op">(</span><span class="nam">test_id</span><span class="op">,</span> <span class="nam">captureStandardOutput</span><span class="op">=</span><span class="str">'true'</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t236" class="pln"><span class="n"><a href="#t236">236</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t237" class="run"><span class="n"><a href="#t237">237</a></span><span class="t">    <span class="key">def</span> <span class="nam">_dump_test_stderr</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">data</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t238" class="mis show_mis"><span class="n"><a href="#t238">238</a></span><span class="t">        <span class="key">if</span> <span class="nam">self</span><span class="op">.</span><span class="nam">current_test_id</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t239" class="mis show_mis"><span class="n"><a href="#t239">239</a></span><span class="t">            <span class="nam">dump_test_stderr</span><span class="op">(</span><span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">,</span> <span class="nam">self</span><span class="op">.</span><span class="nam">current_test_id</span><span class="op">,</span> <span class="nam">self</span><span class="op">.</span><span class="nam">current_test_id</span><span class="op">,</span> <span class="nam">data</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t240" class="pln"><span class="n"><a href="#t240">240</a></span><span class="t">        <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t241" class="mis show_mis"><span class="n"><a href="#t241">241</a></span><span class="t">            <span class="nam">_real_stderr</span><span class="op">.</span><span class="nam">write</span><span class="op">(</span><span class="nam">data</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t242" class="pln"><span class="n"><a href="#t242">242</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t243" class="run"><span class="n"><a href="#t243">243</a></span><span class="t">    <span class="key">def</span> <span class="nam">_dump_test_stdout</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">data</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t244" class="mis show_mis"><span class="n"><a href="#t244">244</a></span><span class="t">        <span class="key">if</span> <span class="nam">self</span><span class="op">.</span><span class="nam">current_test_id</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t245" class="mis show_mis"><span class="n"><a href="#t245">245</a></span><span class="t">            <span class="nam">dump_test_stdout</span><span class="op">(</span><span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">,</span> <span class="nam">self</span><span class="op">.</span><span class="nam">current_test_id</span><span class="op">,</span> <span class="nam">self</span><span class="op">.</span><span class="nam">current_test_id</span><span class="op">,</span> <span class="nam">data</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t246" class="pln"><span class="n"><a href="#t246">246</a></span><span class="t">        <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t247" class="mis show_mis"><span class="n"><a href="#t247">247</a></span><span class="t">            <span class="nam">_real_stdout</span><span class="op">.</span><span class="nam">write</span><span class="op">(</span><span class="nam">data</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t248" class="pln"><span class="n"><a href="#t248">248</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t249" class="run"><span class="n"><a href="#t249">249</a></span><span class="t">    <span class="key">def</span> <span class="nam">_setupStdout</span><span class="op">(</span><span class="nam">self</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t250" class="run"><span class="n"><a href="#t250">250</a></span><span class="t">        <span class="key">if</span> <span class="nam">getattr</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="str">'buffer'</span><span class="op">,</span> <span class="key">None</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t251" class="run"><span class="n"><a href="#t251">251</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">_stderr_buffer</span> <span class="op">=</span> <span class="nam">FlushingStringIO</span><span class="op">(</span><span class="nam">self</span><span class="op">.</span><span class="nam">_dump_test_stderr</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t252" class="run"><span class="n"><a href="#t252">252</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">_stdout_buffer</span> <span class="op">=</span> <span class="nam">FlushingStringIO</span><span class="op">(</span><span class="nam">self</span><span class="op">.</span><span class="nam">_dump_test_stdout</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t253" class="run"><span class="n"><a href="#t253">253</a></span><span class="t">            <span class="nam">sys</span><span class="op">.</span><span class="nam">stdout</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">_stdout_buffer</span>&nbsp;</span><span class="r"></span></p>
    <p id="t254" class="run"><span class="n"><a href="#t254">254</a></span><span class="t">            <span class="nam">sys</span><span class="op">.</span><span class="nam">stderr</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">_stderr_buffer</span>&nbsp;</span><span class="r"></span></p>
    <p id="t255" class="pln"><span class="n"><a href="#t255">255</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t256" class="run"><span class="n"><a href="#t256">256</a></span><span class="t">    <span class="key">def</span> <span class="nam">stopTest</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">test</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t257" class="run"><span class="n"><a href="#t257">257</a></span><span class="t">        <span class="nam">test_id</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">get_test_id_with_description</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t258" class="pln"><span class="n"><a href="#t258">258</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t259" class="run"><span class="n"><a href="#t259">259</a></span><span class="t">        <span class="key">if</span> <span class="nam">getattr</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="str">'buffer'</span><span class="op">,</span> <span class="key">None</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t260" class="pln"><span class="n"><a href="#t260">260</a></span><span class="t">            <span class="com"># Do not allow super() method to print output by itself</span>&nbsp;</span><span class="r"></span></p>
    <p id="t261" class="run"><span class="n"><a href="#t261">261</a></span><span class="t">            <span class="nam">self</span><span class="op">.</span><span class="nam">_mirrorOutput</span> <span class="op">=</span> <span class="key">False</span>&nbsp;</span><span class="r"></span></p>
    <p id="t262" class="pln"><span class="n"><a href="#t262">262</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t263" class="run"><span class="n"><a href="#t263">263</a></span><span class="t">            <span class="nam">output</span> <span class="op">=</span> <span class="nam">sys</span><span class="op">.</span><span class="nam">stdout</span><span class="op">.</span><span class="nam">getvalue</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t264" class="run"><span class="n"><a href="#t264">264</a></span><span class="t">            <span class="key">if</span> <span class="nam">output</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t265" class="mis show_mis"><span class="n"><a href="#t265">265</a></span><span class="t">                <span class="nam">dump_test_stdout</span><span class="op">(</span><span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">,</span> <span class="nam">test_id</span><span class="op">,</span> <span class="nam">test_id</span><span class="op">,</span> <span class="nam">output</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t266" class="pln"><span class="n"><a href="#t266">266</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t267" class="run"><span class="n"><a href="#t267">267</a></span><span class="t">            <span class="nam">error</span> <span class="op">=</span> <span class="nam">sys</span><span class="op">.</span><span class="nam">stderr</span><span class="op">.</span><span class="nam">getvalue</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t268" class="run"><span class="n"><a href="#t268">268</a></span><span class="t">            <span class="key">if</span> <span class="nam">error</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t269" class="mis show_mis"><span class="n"><a href="#t269">269</a></span><span class="t">                <span class="nam">dump_test_stderr</span><span class="op">(</span><span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">,</span> <span class="nam">test_id</span><span class="op">,</span> <span class="nam">test_id</span><span class="op">,</span> <span class="nam">error</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t270" class="pln"><span class="n"><a href="#t270">270</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t271" class="run"><span class="n"><a href="#t271">271</a></span><span class="t">        <span class="nam">super</span><span class="op">(</span><span class="nam">TeamcityTestResult</span><span class="op">,</span> <span class="nam">self</span><span class="op">)</span><span class="op">.</span><span class="nam">stopTest</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t272" class="pln"><span class="n"><a href="#t272">272</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t273" class="run"><span class="n"><a href="#t273">273</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">current_test_id</span> <span class="op">=</span> <span class="key">None</span>&nbsp;</span><span class="r"></span></p>
    <p id="t274" class="pln"><span class="n"><a href="#t274">274</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t275" class="run"><span class="n"><a href="#t275">275</a></span><span class="t">        <span class="key">if</span> <span class="nam">test_id</span> <span class="key">not</span> <span class="key">in</span> <span class="nam">self</span><span class="op">.</span><span class="nam">failed_tests</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t276" class="run"><span class="n"><a href="#t276">276</a></span><span class="t">            <span class="nam">subtest_failures</span> <span class="op">=</span> <span class="nam">self</span><span class="op">.</span><span class="nam">get_subtest_failure</span><span class="op">(</span><span class="nam">test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t277" class="run"><span class="n"><a href="#t277">277</a></span><span class="t">            <span class="key">if</span> <span class="nam">subtest_failures</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t278" class="mis show_mis"><span class="n"><a href="#t278">278</a></span><span class="t">                <span class="nam">self</span><span class="op">.</span><span class="nam">report_fail</span><span class="op">(</span><span class="nam">test</span><span class="op">,</span> <span class="str">"One or more subtests failed"</span><span class="op">,</span> <span class="str">""</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t279" class="pln"><span class="n"><a href="#t279">279</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t280" class="run"><span class="n"><a href="#t280">280</a></span><span class="t">        <span class="key">try</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t281" class="run"><span class="n"><a href="#t281">281</a></span><span class="t">            <span class="nam">time_diff</span> <span class="op">=</span> <span class="nam">datetime</span><span class="op">.</span><span class="nam">datetime</span><span class="op">.</span><span class="nam">now</span><span class="op">(</span><span class="op">)</span> <span class="op">-</span> <span class="nam">self</span><span class="op">.</span><span class="nam">test_started_datetime_map</span><span class="op">[</span><span class="nam">test_id</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
    <p id="t282" class="mis show_mis"><span class="n"><a href="#t282">282</a></span><span class="t">        <span class="key">except</span> <span class="nam">KeyError</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t283" class="mis show_mis"><span class="n"><a href="#t283">283</a></span><span class="t">            <span class="nam">time_diff</span> <span class="op">=</span> <span class="key">None</span>&nbsp;</span><span class="r"></span></p>
    <p id="t284" class="run"><span class="n"><a href="#t284">284</a></span><span class="t">        <span class="nam">self</span><span class="op">.</span><span class="nam">messages</span><span class="op">.</span><span class="nam">testFinished</span><span class="op">(</span><span class="nam">test_id</span><span class="op">,</span> <span class="nam">testDuration</span><span class="op">=</span><span class="nam">time_diff</span><span class="op">,</span> <span class="nam">flowId</span><span class="op">=</span><span class="nam">test_id</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t285" class="pln"><span class="n"><a href="#t285">285</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t286" class="run"><span class="n"><a href="#t286">286</a></span><span class="t">    <span class="key">def</span> <span class="nam">printErrors</span><span class="op">(</span><span class="nam">self</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t287" class="run"><span class="n"><a href="#t287">287</a></span><span class="t">        <span class="key">pass</span>&nbsp;</span><span class="r"></span></p>
    <p id="t288" class="pln"><span class="n"><a href="#t288">288</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t289" class="pln"><span class="n"><a href="#t289">289</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t290" class="run"><span class="n"><a href="#t290">290</a></span><span class="t"><span class="key">class</span> <span class="nam">TeamcityTestRunner</span><span class="op">(</span><span class="nam">TextTestRunner</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t291" class="run"><span class="n"><a href="#t291">291</a></span><span class="t">    <span class="nam">resultclass</span> <span class="op">=</span> <span class="nam">TeamcityTestResult</span>&nbsp;</span><span class="r"></span></p>
    <p id="t292" class="pln"><span class="n"><a href="#t292">292</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t293" class="run"><span class="n"><a href="#t293">293</a></span><span class="t">    <span class="key">if</span> <span class="nam">sys</span><span class="op">.</span><span class="nam">version_info</span> <span class="op">&lt;</span> <span class="op">(</span><span class="num">2</span><span class="op">,</span> <span class="num">7</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t294" class="mis show_mis"><span class="n"><a href="#t294">294</a></span><span class="t">        <span class="key">def</span> <span class="nam">_makeResult</span><span class="op">(</span><span class="nam">self</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t295" class="mis show_mis"><span class="n"><a href="#t295">295</a></span><span class="t">            <span class="key">return</span> <span class="nam">TeamcityTestResult</span><span class="op">(</span><span class="nam">self</span><span class="op">.</span><span class="nam">stream</span><span class="op">,</span> <span class="nam">self</span><span class="op">.</span><span class="nam">descriptions</span><span class="op">,</span> <span class="nam">self</span><span class="op">.</span><span class="nam">verbosity</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t296" class="pln"><span class="n"><a href="#t296">296</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t297" class="run"><span class="n"><a href="#t297">297</a></span><span class="t">    <span class="key">def</span> <span class="nam">run</span><span class="op">(</span><span class="nam">self</span><span class="op">,</span> <span class="nam">test</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t298" class="run"><span class="n"><a href="#t298">298</a></span><span class="t">        <span class="nam">subtest_filter</span> <span class="op">=</span> <span class="key">None</span>&nbsp;</span><span class="r"></span></p>
    <p id="t299" class="run"><span class="n"><a href="#t299">299</a></span><span class="t">        <span class="key">if</span> <span class="nam">sys</span><span class="op">.</span><span class="nam">version_info</span> <span class="op">></span> <span class="op">(</span><span class="num">3</span><span class="op">,</span> <span class="num">3</span><span class="op">)</span><span class="op">:</span>  <span class="com"># No subtests in &lt; 2.4</span>&nbsp;</span><span class="r"></span></p>
    <p id="t300" class="run"><span class="n"><a href="#t300">300</a></span><span class="t">            <span class="key">def</span> <span class="nam">subtest_filter</span><span class="op">(</span><span class="nam">current_test</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t301" class="mis show_mis"><span class="n"><a href="#t301">301</a></span><span class="t">                <span class="key">return</span> <span class="key">not</span> <span class="nam">getattr</span><span class="op">(</span><span class="nam">current_test</span><span class="op">,</span> <span class="str">"_subtest"</span><span class="op">,</span> <span class="key">None</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t302" class="pln"><span class="n"><a href="#t302">302</a></span><span class="t">        <span class="com"># noinspection PyBroadException</span>&nbsp;</span><span class="r"></span></p>
    <p id="t303" class="run"><span class="n"><a href="#t303">303</a></span><span class="t">        <span class="nam">patch_unittest_diff</span><span class="op">(</span><span class="nam">subtest_filter</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t304" class="run"><span class="n"><a href="#t304">304</a></span><span class="t">        <span class="key">try</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t305" class="run"><span class="n"><a href="#t305">305</a></span><span class="t">            <span class="nam">total_tests</span> <span class="op">=</span> <span class="nam">test</span><span class="op">.</span><span class="nam">countTestCases</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t306" class="run"><span class="n"><a href="#t306">306</a></span><span class="t">            <span class="nam">TeamcityServiceMessages</span><span class="op">(</span><span class="nam">_real_stdout</span><span class="op">)</span><span class="op">.</span><span class="nam">testCount</span><span class="op">(</span><span class="nam">total_tests</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t307" class="mis show_mis"><span class="n"><a href="#t307">307</a></span><span class="t">        <span class="key">except</span> <span class="nam">Exception</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t308" class="mis show_mis"><span class="n"><a href="#t308">308</a></span><span class="t">            <span class="key">pass</span>&nbsp;</span><span class="r"></span></p>
    <p id="t309" class="pln"><span class="n"><a href="#t309">309</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t310" class="run"><span class="n"><a href="#t310">310</a></span><span class="t">        <span class="key">return</span> <span class="nam">super</span><span class="op">(</span><span class="nam">TeamcityTestRunner</span><span class="op">,</span> <span class="nam">self</span><span class="op">)</span><span class="op">.</span><span class="nam">run</span><span class="op">(</span><span class="nam">test</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
    <p id="t311" class="pln"><span class="n"><a href="#t311">311</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t312" class="pln"><span class="n"><a href="#t312">312</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t313" class="run"><span class="n"><a href="#t313">313</a></span><span class="t"><span class="key">if</span> <span class="nam">__name__</span> <span class="op">==</span> <span class="str">'__main__'</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
    <p id="t314" class="mis show_mis"><span class="n"><a href="#t314">314</a></span><span class="t">    <span class="key">from</span> <span class="nam">unittest</span> <span class="key">import</span> <span class="nam">main</span>&nbsp;</span><span class="r"></span></p>
    <p id="t315" class="pln"><span class="n"><a href="#t315">315</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
    <p id="t316" class="mis show_mis"><span class="n"><a href="#t316">316</a></span><span class="t">    <span class="nam">main</span><span class="op">(</span><span class="nam">module</span><span class="op">=</span><span class="key">None</span><span class="op">,</span> <span class="nam">testRunner</span><span class="op">=</span><span class="nam">TeamcityTestRunner</span><span class="op">(</span><span class="op">)</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
</div>
<div id="footer">
    <div class="content">
        <p>
            <a class="nav" href="index.html">&#xab; index</a> &nbsp; &nbsp; <a class="nav" href="https://coverage.readthedocs.io">coverage.py v5.1</a>,
            created at 2020-06-08 16:42
        </p>
    </div>
</div>
</body>
</html>
